- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.7k
          feat(core): Add inheritOrSampleWith helper to traceSampler
          #15277
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| sampleRate = options.tracesSampler(samplingContext); | ||
| sampleRate = options.tracesSampler({ | ||
| ...samplingContext, | ||
| inheritOrSampleWith(fallbackSampleRate) { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| inheritOrSampleWith(fallbackSampleRate) { | |
| inheritOrSampleWith: (fallbackSampleRate) => { | 
is this maybe slightly cleaner regarding this context? 🤔
|  | ||
| // Fallback if parent sample rate is not on the incoming trace (e.g. if there is no baggage) | ||
| if (typeof samplingContext.parentSampled === 'boolean') { | ||
| return 1; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| return 1; | |
| return Number(samplingContext.parentSampled); | 
!! otherwise this would propagate 1 for false :D
| size-limit report 📦
 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sweet!
| Should we backport this? 🤔 I think it may be worth it, makes docs much easier in that regard..? | 
In #15277, `TracesSamplerSamplingContext` is added to and exported from [types-hoist], but is not being exported from [index.ts]. I'm following the [instruction], and I want to inject `(samplingContext: TracesSamplerSamplingContext) => number | boolean` to a function that is wrapping `Sentry.init`, but I can't because `TracesSamplerSamplingContext` is not recognized :( <!--link--> [types-hoist]: https://github.com/getsentry/sentry-javascript/blob/14eba5676149317f2e2b31143a0590256d32c094/packages/core/src/types-hoist/samplingcontext.ts#L47 [index.ts]: https://github.com/getsentry/sentry-javascript/blob/14eba5676149317f2e2b31143a0590256d32c094/packages/core/src/index.ts#L403 [instruction]: https://docs.sentry.io/platforms/javascript/guides/react/tracing/configure-sampling/#sampling-function-tracessampler
We found in getsentry/sentry-docs#12544 that the proposed ux is horrible because nobody would understand what it does, so we're adding a helper that facilitates inheriting a sampling decision that also allows for catching more edge-cases without worsening ux and is self explanatory in what it does.